const express = require('express')

// 创建 express 的服务器实例
const app = express()
const cors = require('cors')
app.use(cors())
    // 配置解析 application/x-www-form-urlencoded 格式的表单数据的中间件
app.use(express.urlencoded({ extended: false }))





// 响应数据的中间件
app.use(function(req, res, next) {
    // status = 0 为成功； status = 1 为失败； 默认将 status 的值设置为 1，方便处理失败的情况
    res.cc = function(err, status = 1) {
        res.send({
            // 状态
            status,
            // 状态描述，判断 err 是 错误对象 还是 字符串
            message: err instanceof Error ? err.message : err,
        })
    }
    next()
})
const joi = require('joi')
    // 错误中间件
app.use(function(err, req, res, next) {
    // 数据验证失败
    if (err instanceof joi.ValidationError) return res.cc(err)

    // 未知错误
    res.cc(err)
        // 捕获身份认证失败的错误
    if (err.name === 'UnauthorizedError') return res.cc('身份认证失败！')

})

// 导入配置文件
const config = require('./config')
    // 解析 token 的中间件
const expressJWT = require('express-jwt')

app.use(expressJWT({ secret: config.jwtSecretKey }).unless({
    path: [/^\/api\//]
}))




// const bodyParser = require("body-parser");
// //挂载body-parser
// //要注意body-parser在项目代码中的挂载位置
// //应该挂载的位置是：在使用路由之前
// //项目入口文件会挂载我们编写好的路由，就是放在这些路由的前面













const userRouter = require('./router/user')
app.use('/api', userRouter)


// 导入并使用用户信息路由模块
const userinfoRouter = require('./router/userinfo')
    // 注意：以 /my 开头的接口，都是有权限的接口，需要进行 Token 身份认证
app.use('/my', userinfoRouter)

// 导入并使用文章分类路由模块
const artCateRouter = require('./router/artcate')
    // 为文章分类的路由挂载统一的访问前缀 /my/article
app.use('/my/article', artCateRouter)


// 导入并使用文章路由模块
const articleRouter = require('./router/article')
    // 为文章的路由挂载统一的访问前缀 /my/article
app.use('/my/article', articleRouter)
    // 托管静态资源文件
app.use('/uploads', express.static('./uploads'))






















// 调用 app.listen 方法，指定端口号并启动web服务器
app.listen(3110, function() {
    console.log('api server running at http://127.0.0.1:3110')
})